package com.hao.leetcode;

//实现 strStr() 函数。
//
// 给定一个 haystack 字符串和一个 needle 字符串，在 haystack 字符串中找出 needle 字符串出现的第一个位置 (从0开始)。如
//果不存在，则返回 -1。
//
// 示例 1:
//
// 输入: haystack = "hello", needle = "ll"
//输出: 2
//
//
// 示例 2:
//
// 输入: haystack = "aaaaa", needle = "bba"
//输出: -1
//
//
// 说明:
//
// 当 needle 是空字符串时，我们应当返回什么值呢？这是一个在面试中很好的问题。
//
// 对于本题而言，当 needle 是空字符串时我们应当返回 0 。这与C语言的 strstr() 以及 Java的 indexOf() 定义相符。
// Related Topics 双指针 字符串
// 👍 554 👎 0
public class Demo28 {
    public static void main(String[] args) {
        Demo28 demo = new Demo28();
        /*int result = demo.strStr("hello", "ll");
        System.out.println(result);
        result = demo.strStr("aaaaa", "bba");
        System.out.println(result);*/
        int result = demo.strStr("mississippi", "pi");
        System.out.println(result);
    }

    public int strStr(String haystack, String needle) {
        if ("".equals(needle) || haystack.equals(needle)) {
            return 0;
        }

        int m = haystack.length();
        int n = needle.length();

        for (int i = 0; i <= m - n; i++) {
            int j;
            for (j = 0; j < n; j++) {
                if (needle.charAt(j) != haystack.charAt(i + j)) {
                    break;
                }
            }
            if (j == n) {
                return i;
            }
        }

        return -1;
    }
}
